# PATENT ABSTRACTS OF JAPAN

(11) Publication number: 2002163322 A

(43) Date of publication of application: 07.06.02

(51) Int. CI

G06F 17/50 G01R 31/28

(21) Application number: 2000363053

(22) Date of filing: 29.11.00

(71) Applicant:

NEC MICROSYSTEMS LTD

(72) Inventor:

**EZAKI KUMIKO** 

# (54) METHOD AND DEVICE FOR VERIFYING LOGIC CIRCUIT

# (57) Abstract:

PROBLEM TO BE SOLVED: To exactly detect a spot, where a through current is generated by an HiZ entry, in a logic simulation.

SOLUTION: This device is provided with a floating deciding part 3 for detecting a spot, where the through current is generated by gate floating of an MOS transistor caused by an HiZ value entry making the output of a verification target cell into unfixed value, on the basis of a decision function F34 prepared from the circuit chart of a real device, which does not depend on the description of a library F3 for logic simulation in a verification target circuit.

COPYRIGHT: (C)2002,JPO



# (19)日本国特許庁 (JP) (12) 公開特許公報 (A)

(11)特許出願公開番号 特開2002-163322

(P2002 - 163322A)

(43)公開日 平成14年6月7日(2002.6.7)

(51) Int.Cl.7

識別記号

FΙ G06F 17/50 テーマコート\*(参考)

G06F 17/50

664 672

664A 2G032 672A 5B046

G01R 31/28

G01R 31/28

F

審査請求 有 請求項の数11 OL (全 19 頁)

(21)出願番号

特願2000-363053(P2000-363053)

(22)出願日

平成12年11月29日(2000, 11, 29)

(71)出願人 000232036

エヌイーシーマイクロシステム株式会社 神奈川県川崎市中原区小杉町1丁目403番

53

(72) 発明者 江崎 久美子

神奈川県川崎市中原区小杉町一丁目403番 53 日本電気アイシーマイコンシステム株

式会社内

(74)代理人 100082935

弁理士 京本 直樹 (外2名)

Fターム(参考) 20032 AA01 AB20 AC08 AC02 5B046 AA08 BA03 KA06

#### (54) 【発明の名称】 論理回路検証方法とその装置

# (57) 【要約】

【課題】論理シミュレーション時に、HiZ入力による 貫通電流発生個所を正確に検出可能とする。

【解決手段】検証対象回路の論理シミュレーション用ラ イブラリF3の記述に依存しない実際のデバイスの回路 図から作成した判定関数F34に基づき検証対象セルの 出力が不定値となるHiZ値入力に起因するMOSトラ ンジスタのゲートフローティングで起こる貫通電流発生 箇所を検出するフローティング判定部3を備える。



【特許請求の範囲】

【請求項1】 検証対象回路の論理回路データとテストデータとに基づき検証対象の論理回路の論理素子であるファンクションセルの出力の値であるネット値を観測することにより、動作状態をシミュレーションして論理検証を行う論理回路検証方法において、

前記検証対象回路の論理シミュレーション用ライブラリの記述に依存しない実際のデバイスの回路図から作成した判定関数に基づき論理検証の対象とする前記ファンクションセルである検証対象セルの出力が不定値となる高 10 インピーダンス (以下、HiZ) 値入力に起因するMO Sトランジスタのゲートフローティングで起こる貫通電流発生箇所を的確に検出することを特徴とする論理回路検証方法。

【請求項2】 検証対象回路の論理回路データとテストデータとに基づき検証対象の論理回路の論理素子であるファンクションセルの出力の値であるネット値を観測することにより、動作状態をシミュレーションして論理検証を行う論理回路検証方法において、

シミュレーション開始後、使用者が設定した検証時刻に 到達した時に入力値検出部を呼び出す入力値検出部呼出 ステップと、

前記検証対象回路で使用されている論理検証用ライブラリのファンクションセルである検証対象セルのセル名を 獲得するセル名獲得ステップと、

前記検証対象セルに入力されるデータ入力値を獲得する 入力値獲得ステップと、

前記検証対象セルの前記セル名から該当するフローティング判定の判定関数を呼び出す判定関数呼出ステップと、

前記判定関数での判定条件と一致するかの判定を行うフローティング判定ステップと、

前記フローティング判定ステップで一致する場合エラー 又はワーニングと判定するエラー又はワーニング判定ス テップと、

検証対象の全てのファンクションセルについて前記入力 値検出部呼出ステップから前記エラー又はワーニング判 定ステップまでの処理を反復するファンクションセル終 了確認ステップと、

シミュレーション終了時刻まで検証時刻に到達する毎に 前記前記入力値検出部呼出ステップから前記反復処理ス テップまでの処理を繰り返すシミュレーション終了判定 ステップとを有することを特徴とする論理回路検証方 法。

【請求項3】 前記フローティング判定ステップが、第1の入力信号が高インピーダンス(以下、HiZ)値であるかの判定を行う第1の入力信号の判定ステップと、前記第1の入力信号の判定ステップでHiZ値の場合エラー又はゲートフローティングによる貫通電流発生を出力する第1の出力ステップと、

前記第1の入力信号の判定ステップでHiZ値でない場合と前記第1の出力ステップの後、第2の入力信号がHiZ値であるかの判定を行う第2の入力信号の判定ステップと、

前記第2の入力信号の判定ステップでHiZ値の場合エラー又はゲートフローティングによる貫通電流発生を出力する第2の出力ステップと、

前記第1の入力信号の判定ステップでHiZ値でない場合と前記第2の出力ステップの後、第3の入力信号がHiZ値であるかの判定を行う第3の入力信号の判定ステップと、

前記第3の入力信号の判定ステップでHiZ値の場合エラー又はゲートフローティングによる貫通電流発生を出力する第3の出力ステップとを有することを特徴とする請求項2記載の論理回路検証方法。

【請求項4】 前記判定関数呼出ステップの後、該当する判定関数の有無を判定する判定関数有無判定ステップと、

判定関数がない場合に検証対象外であることを警告する の 検証対象外警告ステップとを有することを特徴とする請 求項2記載の論理回路検証方法。

【請求項5】 検証対象回路の論理回路データとテストデータとに基づき検証対象の論理回路の論理素子であるファンクションセルの出力の値であるネット値を観測することにより、動作状態をシミュレーションして論理検証を行う論理回路検証方法において、

シミュレーション開始後、使用者が設定した検証時刻に 到達した時に入力値検出部を呼び出す入力値検出部呼出 ステップと、

30 前記検証対象回路で使用されている論理検証用ライブラ リのファンクションセルである検証対象セルのセル名を 獲得するセル名獲得ステップと、

前記検証対象セルに入力されるデータ入力値を獲得する 入力値獲得ステップと、

前記検証対象セルの前記セル名から該当するフローティング判定の判定関数を呼び出す判定関数呼出ステップレ

使用者が指定した指定信号を格納した指定信号リストから前記指定信号の名称である指定信号名を受け、検出対象セルの入力信号名が指定信号名と一致しかつ入力信号値がHiZであるかを判定する指定信号のHiZ判定ステップと、

前記指定信号のHi Z判定ステップで指定信号がHi Z の場合前記入力信号が直接接続されている回路の構成と無関係に全てエラーと判定するエラー判定ステップと、前記指定信号のHi Z判定ステップで指定信号がHi Z でない場合前記判定関数での判定条件と一致するかを判定するフローティング判定ステップと、

前記フローティング判定ステップで一致する場合エラー 50 又はワーニングと判定するエラー又はワーニング判定ス 3

テップと、

検証対象の全てのファンクションセルについて前記入力 値検出部呼出ステップから前記エラー又はワーニング判 定ステップまでの処理を反復するファンクションセル終 了確認ステップと、

シミュレーション終了時刻まで検証時刻に到達する毎に 前記前記入力値検出部呼出ステップから前記反復処理ス テップまでの処理を繰り返すシミュレーション終了判定 ステップちおを有することを特徴とする論理回路検証方 法。

【請求項6】 検証対象回路の論理回路データとテスト データとに基づき検証対象の論理回路の論理素子である ファンクションセルの出力の値であるネット値を観測す ることにより、動作状態をシミュレーションして論理検 証を行う論理回路検証方法において、

シミュレーション開始後、設定した検証時刻に到達した 時に入力値検出部を呼び出す入力値検出部呼出ステップ と、

論理検証用ライブラリから使用者が指定した指定信号が 入力されているファンクションセルである検証対象セル 20 のセル名を獲得する指定信号セル名獲得ステップと、 前記検証対象セルに入力されるデータ入力値を獲得する 入力値獲得ステップと、

前記検証対象セルの前記セル名から該当するフローティ ング判定の判定関数を呼び出す判定関数呼出ステップ

前記使用者が作成した指定信号リストの指定信号名と検 出した信号名とが一致する場合に前記判定関数での判定 条件と一致するかの判定を行うフローティング判定ステ ップと、

前記フローティング判定ステップで一致する場合エラー 又はワーニングと判定するエラー又はワーニング判定ス テップと、

検証対象の全ての指定信号について前記入力値検出部呼 出ステップから前記エラー又はワーニング判定ステップ までの処理を反復するファンクションセル終了確認ステ ップと、

シミュレーション終了時刻まで検証時刻に到達する毎に 前記前記入力値検出部呼出ステップから前記反復処理ス テップまでの処理を繰り返すシミュレーション終了判定 ステップとを有することを特徴とする論理回路検証方 法。

【請求項7】 検証対象回路の論理回路データとテスト データとに基づき検証対象の論理回路の論理素子である ファンクションセルの出力の値であるネット値を観測す ることにより、動作状態をシミュレーションして論理検 証を行う論理回路検証装置において、

前記検証対象回路の論理シミュレーション用ライブラリ の記述に依存しない実際のデバイスの回路図から作成し

ションセルである検証対象セルの出力が不定値となる高 インピーダンス(以下、HiZ)値入力に起因するMO Sトランジスタのゲートフローティングで起こる貫通電 流発生箇所を検出するフローティング判定部を備えるこ とを特徴とする論理回路検証装置。

【請求項8】 検証対象回路の論理回路データとテスト データとに基づき検証対象の論理回路の論理素子である ファンクションセルの出力の値であるネット値を観測す ることにより、動作状態を論理シミュレーションして論 10 理検証を行う論理回路検証装置において、

前記テストデータと前記論理回路データとを入力しこの 論理回路データが参照する後述のファンクションセルの 集まりである論理検証用ライブラリを参照して前記論理 シミュレーションを行うシミュレータと、

前記シミュレータから検証対象の前記ファンクションセ ルである検証対象セルのセル名と入力値を抽出し出力す る入力値検出部と、

抽出した前記検証対象セルのセル名と前記入力値と前記 検出対象セルの実際のデバイスの回路図から作成した判 定関数とに基づき前記検出対象回路が高インピーダンス 入力によるゲートフローティングで貫通電流が発生する かの判定を行い判定結果のメッセージを出力するフロー ティング判定部と、

前記シミュレータのシミュレーション結果と前記フロー ティング判定部の前記メッセージに基づきシミュレーシ ョン結果と判定結果を出力する出力処理部とを備えるこ とを特徴とする論理回路検証装置。

【請求項9】 前記フローティング判定部が、前記入力 値検出部で抽出した前記セル名と前記判定関数とセル名 の対応リストを参照して前記判定関数を格納した判定関 30 数ファイルから前記検証対象セルの判定関数を選択する 判定関数選択部と、

前記判定関数と前記セル名のセルの前記入力値とからゲ ートフローティングによる貫通電流の発生の有無を判定 し判定結果をメッセージとして出力する判定部とを備え ることを特徴とする請求項8記載の論理回路検証装置。

【請求項10】 検証対象回路の論理回路データとテス トデータとに基づき検証対象の論理回路の論理素子であ るファンクションセルの出力の値であるネット値を観測 することにより、動作状態を論理シミュレーションして 論理検証を行う論理回路検証装置において、

前記テストデータと前記論理回路データとを入力しこの 論理回路データが参照する後述のファンクションセルの 集まりである論理検証用ライブラリを参照して前記論理 シミュレーションを行うシミュレータと、

前記シミュレータから検証対象の前記ファンクションセ ルである検証対象セルのセル名と入力値を抽出し出力す る入力値検出部と、

抽出した前記検証対象セルのセル名と前記入力値と前記 た判定関数に基づき論理検証の対象とする前記ファンク 50 検出対象セルの実際のデバイスの回路図から作成した判

定関数と入力信号の種類と入力信号が接続されている回 路の種類とに基づき前記検出対象回路が高インピーダン ス入力によるゲートフローティングで貫通電流が発生す るかの判定を行い判定結果のメッセージを出力するフロ ーティング判定部と、

前記フローティング判定部に必要な前記入力信号の種類 と前記入力信号が接続されている回路の種類を論理検証 用ライブラリと同一階層構造を持つSPICEネットリ ストから抽出するための回路構成抽出部と、

前記シミュレータのシミュレーション結果と前記フロー ティング判定部の前記メッセージに基づきシミュレーシ ョン結果と判定結果を出力する出力処理部とを備えるこ とを特徴とする論理回路検証装置。

【請求項11】 検証対象回路の論理回路データとテス トデータとに基づき検証対象の論理回路の論理素子であ るファンクションセルの出力の値であるネット値を観測 することにより、動作状態を論理シミュレーションして 論理検証を行う論理回路検証装置において、

前記テストデータと前記論理回路データとを入力しこの 論理回路データが参照する後述のファンクションセルの 20 集まりである論理検証用ライブラリを参照して前記論理 シミュレーションを行うシミュレータと、

前記シミュレータから検証対象の前記ファンクションセ ルである検証対象セルのセル名と入力値を抽出し出力す る入力値検出部と、

抽出した前記検証対象セルのセル名と前記入力値と前記 検出対象セルの実際のデバイスの回路図から作成した判 定関数とに基づき前記検出対象回路が高インピーダンス 入力によるゲートフローティングで貫通電流が発生する かの判定を行うとともに使用者が指定した指定信号につ 30 いては入力信号が直接接続されている回路の構成と無関 係にデータ入力値が髙インピーダンス値である場合は全 てエラーと判定して判定結果のメッセージを出力するフ ローティング判定部と、

前記シミュレータのシミュレーション結果と前記フロー ティング判定部の前記メッセージに基づきシミュレーシ ョン結果と判定結果を出力する出力処理部とを備えるこ とを特徴とする論理回路検証装置。

### 【発明の詳細な説明】

#### [0001]

【発明の属する技術分野】本発明は論理回路検証方法と その装置に関し、特にCMOS論理回路から成る論理L SIにおける論理回路検証方法とその装置に関する。

# [0002]

【従来の技術】近年、半導体集積回路(LSI)、特に CMOS論理回路から成る論理LSIの回路規模は飛躍 的に増大し、これらの開発にはCAD(コンピュータ支 援設計)装置を用いて行うのが主流となっている。さら に、それらの接続規約(ルール)を人手でチェックする

うことにより接続規約を検証するCAD装置を用いた方 法が広く行われている。

【0003】この種の論理検証として、検証対象回路の 論理回路データとテストデータとに基づき検証対象回路 の論理回路データのネット値を観測することにより、動 作状態をシミュレーションして論理検証を行う動的論理 検証と、検証対象回路の接続情報を示すネットリストと 論理回路の回路情報を示すライブラリとを用いて検証ル ールに基づいて論理回路の接続状態が正しいか否かを判 定する静的論理検証がある。

【0004】プロセスの微細化が進む中、民生機器やモ バイル用途では以前にもまして待機状態(スタンバイモ ード)における電力消費が問題となってきている。実際 のデバイスでの評価時に消費電力大の問題が発見される ことは大きな後戻りを生じさせ、製品の市場投入時期を 遅らせることになる。本問題の設計上の原因として髙イ ンピーダンス(以下、HiZ)入力によるMOSトラン ジスタのゲートフローティングで起こる貫通電流があげ られる。すなわち、HiZ入力によりゲート電位が不安 定となり中間電位のときにPチャネルランジスタおよび Nチャネルトランジスタが同時にオンすることによる貫 通電流が発生する。本原因はゲートレベルでの論理シミ ュレーションにより発見できる要因である。しかしなが ら、従来の論理回路検証方法とその装置では、HiZ入 力によるゲートフローティングを検出できたとしても、 その検出箇所には論理シミュレーション用に付加した実 際のデバイスには存在しない付加記述素子に起因するX 値発生個所の検出箇所である擬似エラーを含むという問 題があった。

【0005】従来の動的論理検証システムの例である、 特開平06-016646号公報記載の従来の第1の論 理検証装置をブロックで示す図17を参照すると、この 従来の第1の論理回路検証装置は、テストデータF10 1とシミュレーションの対象となる論理回路データF1 02とを入力しシミュレーションを行うシミュレータ1 01と、シミュレータ101の出力したネット値 "0", "1", "不定値(X)"を検出する出力検出 部102と、出力検出部102の検出結果を処理しシミ ュレーション結果F103を出力する出力処理部103 とを備える。

【0006】出力検出部102は、"0"を検出する "0"検出部1021と、"1"を検出する"1"検出 部1022と、"X"を検出する"X"検出部1023 とを備える。

【0007】次に、図17を参照して従来の第1の論理 回路検証装置の動作について説明すると、テストデータ F101と回路構造を記述した論理回路データF102 をシミュレータ101に入力する。シミュレータ101 は、検証対象の論理回路の論理素子出力の値、すなわち のは非常に困難であり、このため、自動で論理検証を行 50 ネット値を出力する。出力検出部102は、シミュレー

タ101が出力したネット値のうち"0", "1", "X"だけ検出し、出力処理部103に出力する。出力 処理部103は、入力したネット値とその変化を"0" から"1"かつ"1"から"0"の変化をしたもの、 "1"にならないもの、"0"にならないもの、ずっと "X" のままであるものをそれぞれ集計し、どのネット がどの動作をしたかを分析してシミュレーション結果F 103として出力する。

【0008】しかしながら、上述した従来の第1の論理 検証装置では、論理シミュレーションでネット値に不定 (X) 値が発生する個所を検出しているが、検出したX 値発生箇所は実際のデバイスにおいて、HiZ値入力に よるゲートフローティングで貫通電流が発生する個所 (以下、真のエラー) と同一個所ではない場合があっ た。

【0009】その理由は、論理シミュレーション用ライ ブラリには論理シミュレータに依存した遅延値の貼り付 けや論理整合性をとるための実際には存在しないバッフ ア等を付加した付加記述があり、このような論理シミュ レーション用ライブラリの論理シミュレーションにより HiZ入力によるX発生を検出した場合、X値発生個所 は上記付加記述したバッファ等(以下、付加記述素子) でもあり得る。従って、X値発生個所はシミュレーショ ン用ライブラリ記述に依存し、X値発生個所が実際のデ バイスでは発生しない上記付加記述素子をも検出するこ とになる(以下、検出した付加記述素子によるX値発生 個所を擬似エラーと呼ぶ) ためである。

【0010】論理シミュレーション用ライブラリの一例 としてトライステートバッファの論理記述を模式的に回 路図で表した図19 (A)を参照すると、データ信号D の入力に応じてデータ信号D0を出力するバッファB1 1と、コントロール信号ENの入力に応じてコントロー ル信号EN0を出力するバッファB12と、コントロー ル信号ENOの値が1のときデータ信号DOの入力に応 じて出力信号Qを出力するトライステートバッファB1 3とを有する。ここで、バッファ B 1 1 は遅延値整合用 の付加記述素子であり、実際のデバイスには存在しな い。論理シミュレーションにおいて、データ信号DにH i Zを入力した(設定した)場合、コントロール信号E Nの値と無関係にバッファB11の出力のデータ信号D 0はXとなる。すなわち、X値発生個所は、実際のデバ イスには存在しないバッファB11であり、疑似エラー となる。

【0011】また、データ信号DにHiZを入力した場 合でもコントロール信号ENがOの場合は、トライステ ートバッファB13を構成する論理素子の出力にゲート のフローティングによる貫通電流は発生しないため、真 のエラーに無関係な疑似エラーを出力する。

【0012】すなわち、従来の第1の論理検証装置で は、検出したX値発生個所に擬似エラーも含まれている ため真のエラー検出のためには、出力したX値発生個所 検出結果を解析する時間が必要であった。さらに、疑似 エラーの多さから真のエラーを見逃すこともあった。

【0013】従来の静的論理検証システムの例である、 特開平10-334124号号公報記載の従来の第2の 論理検証装置をブロックで示す図18を参照すると、こ の従来の第2の論理回路検証装置は、論理回路図を作成 する論理回路図作成装置201と、論理回路図作成装置 201で作成した回路図の論理回路相互間の接続情報を 10 示すネットリストを入力するネットリスト入力部202 と、論理回路の回路情報を示すライブラリを入力するラ イブラリ入力部203と、検証を行う検証部204と、 検証結果を出力するエラー/ワーニング出力部205 と、論理回路の検証ルールを記憶した検証ルール記憶領 域206とを備える。

【0014】次に、図18を参照して従来の第2の論理 回路検証装置の動作について説明すると、入力されたネ ットリストのトライステートバッファに着目し、このト ライステートバッファのコントロール端子の接続状態と ライブラリの情報とから検証ルールに従ってHiZ状態 でのゲートのフローティングが発生する(フローティン グエラー)かを判定する。なお、この例の上記ライブラ リの情報は、論理回路の回路情報としてトライステート バッファのコントロール端子のレベル状態と出力値の関 係を記述したものである。また、上記検証ルールは、ト ライステートバッファがHiZ状態になると判断した場 合に、トライステートバッファの出力ピンが次段の論理 回路の1つの入力に接続されているときにフローティン グエラーとする。

【0015】この、従来の第2の論理検証装置では、ト ライステートバッファのコントロール端子の接続状態と からHiZ値出力の可能性を判断し、トライステートバ ッファ出力信号の共有数から次段の論理回路のゲートに フローティングが発生するかを判定しているため、コン トロール端子が電源VDD、接地GNDに直接接続され ていない場合はコントロール端子へ入力される信号値は シミュレーションを行わなければ判明しないため正確な HiZ入力によるゲートフローティングを検出できな い。

【0016】従来の第2の論理回路検証装置の検証個所 のライブラリの論理記述を模式的に回路図で示す図19 (B) を参照すると、コントロール信号EN1の値に応 じて出力のオンオフを行い入力したデータ信号Dに応じ た出力のデータ信号Q1の出力を制御するトライステー トバッファB21と、データ信号Q1の供給を受けデー タ信号Q2を出力する論理回路(バッファ)B22と、 コントロール信号EN2の値に応じて出力のオンオフを 行い入力したデータ信号Q2に応じた出力信号Q3の出 力を制御するトライステートバッファB23とを有す 50 る。

【0017】検証部204は、ライブラリ入力部203からの上記ライブラリ論理記述に基づき、トライステートバッファB21のコントロール信号EN1の値に依存してトライステートバッファB21の出力のデータ信号Q1としてHiZが出力される可能性を判断し、HiZが出力されデータ信号Q1が単独で次段のバッファB22に接続(入力)されている場合をフローティングエラー(HiZ入力によるゲートフローティング発生)と判断している。

【0018】しかし、次段のバッファB22は論理検証 10 用ライブラリに追加された疑似のバッファであり、バッファB21のコントロール信号EN1の値は、コントロール信号EN1の入力するコントロール端子が直接電源 VDD、又は接地GNDに接続されていない場合は、シミュレーションしなければ判明せず、次段のバッファB22の出力データ信号Q2が接続(入力)されている次段のトライステートバッファB23がコントロール信号EN2がオフしていればこのトライステートバッファB23では貫通電流が発生しない。 20

【0019】しかし、従来の第2の論理回路検証装置では、上述したように、トライステートバッファB21で必ずフローティングエラーを検出するため、擬似エラーが発生する可能性がある。

# [0020]

【発明が解決しようとする課題】上述した従来の第1の論理回路検証方法とその装置は、論理シミュレーションでネット値に不定(X)値が発生する個所を検出しているが、論理シミュレーション用ライブラリに論理シミュレータに依存した遅延値の貼り付けや論理整合性をとるための実際には存在しないバッファ等の付加記述素子に起因したX値発生個所である擬似エラーを含むため、検出したX値発生箇所は実際のデバイスにおいて、高インピーダンス(HiZ)値入力によるゲートフローティングで貫通電流が発生する個所である真のエラーと同一個所ではない、すなわち、検出したX値発生個所に擬似エラーも含まれているため、真のエラー検出のためには、出力したX値発生個所検出結果を解析する時間が必要であるという欠点があった。

【0021】また、疑似エラーの多さから真のエラーを 40 見逃すこともあるという欠点があっった。

【0022】また、従来の第2の論理回路検証方法とその装置は、トライステートバッファのコントロール端子の接続状態とからHiZ値出力の可能性を判断し、トライステートバッファ出力信号の共有数から次段の論理回路のゲートにフローティングが発生するかを判定しているため、コントロール端子が電源VDD、接地GNDに直接接続されていない場合は、コントロール端子への入力信号値はシミュレーション実施によらなければ不明なことにより正確なHiZ入力によるゲートフローティン

グを検出できないため、擬似エラーが発生する可能性が あるという欠点があった。

【0023】本発明の目的は、論理シミュレーション時に、HiZ入力によりゲート電位が不安定となり中間電位のときにPチャネルランジスタおよびNチャネルトランジスタが同時にオンすることによる貫通電流発生個所を正確に検出できる論理回路検証方法とその装置を提供することにある。

### [0024]

10 【課題を解決するための手段】請求項1記載の発明の論理回路検証方法は、検証対象回路の論理回路データとテストデータとに基づき検証対象の論理回路の論理素子であるファンクションセルの出力の値であるネット値を観測することにより、動作状態をシミュレーションして論理検証を行う論理回路検証方法において、前記検証対象回路の論理シミュレーション用ライブラリの記述に依存しない実際のデバイスの回路図から作成した判定関数に基づき論理検証の対象とする前記ファンクションセルである検証対象セルの出力が不定値となる高インピーダンス(以下、HiZ)値入力に起因するMOSトランジスタのゲートフローティングで起こる貫通電流発生箇所を的確に検出することを特徴とするものである。

【0025】請求項2記載の発明の論理回路検証方法 は、検証対象回路の論理回路データとテストデータとに 基づき検証対象の論理回路の論理素子であるファンクシ ョンセルの出力の値であるネット値を観測することによ り、動作状態をシミュレーションして論理検証を行う論 理回路検証方法において、シミュレーション開始後、使 用者が設定した検証時刻に到達した時に入力値検出部を 呼び出す入力値検出部呼出ステップと、前記検証対象回 路で使用されている論理検証用ライブラリのファンクシ ョンセルである検証対象セルのセル名を獲得するセル名 獲得ステップと、前記検証対象セルに入力されるデータ 入力値を獲得する入力値獲得ステップと、前記検証対象 セルの前記セル名から該当するフローティング判定の判 定関数を呼び出す判定関数呼出ステップと、前記判定関 数での判定条件と一致するかの判定を行うフローティン グ判定ステップと、前記フローティング判定ステップで 一致する場合エラー又はワーニングと判定するエラー又 はワーニング判定ステップと、検証対象の全てのファン クションセルについて前記入力値検出部呼出ステップか ら前記エラー又はワーニング判定ステップまでの処理を 反復するファンクションセル終了確認ステップと、シミ ュレーション終了時刻まで検証時刻に到達する毎に前記 前記入力値検出部呼出ステップから前記反復処理ステッ プまでの処理を繰り返すシミュレーション終了判定ステ ップとを有することを特徴とするものである。

直接接続されていない場合は、コントロール端子への入 【0026】また、請求項3記載の発明は、請求項2記 力信号値はシミュレーション実施によらなければ不明な 載の論理回路検証方法において、前記フローティング判 ことにより正確なHiZ入力によるゲートフローティン・50 定ステップが、第1の入力信号が高インピーダンス(以

下、HiZ) 値であるかの判定を行う第1の入力信号の 判定ステップと、前記第1の入力信号の判定ステップで HiZ値の場合エラー又はゲートフローティングによる 貫通電流発生を出力する第1の出力ステップと、前記第 1の入力信号の判定ステップでHiZ値でない場合と前 記第1の出力ステップの後、第2の入力信号がHiZ値 であるかの判定を行う第2の入力信号の判定ステップ と、前記第2の入力信号の判定ステップでHiZ値の場 合エラー又はゲートフローティングによる貫通電流発生 を出力する第2の出力ステップと、前記第1の入力信号 の判定ステップでHiZ値でない場合と前記第2の出力 ステップの後、第3の入力信号がHiZ値であるかの判 定を行う第3の入力信号の判定ステップと、前記第3の 入力信号の判定ステップでHiZ値の場合エラー又はゲ ートフローティングによる貫通電流発生を出力する第3 の出力ステップとを有することを特徴とするものであ

【0027】また、請求項4記載の発明は、請求項2記 載の論理回路検証方法において、前記判定関数呼出ステ ップの後、該当する判定関数の有無を判定する判定関数 有無判定ステップと、判定関数がない場合に検証対象外 であることを警告する検証対象外警告ステップとを有す ることを特徴とするものである。

【0028】請求項5記載の発明の論理回路検証方法 は、検証対象回路の論理回路データとテストデータとに 基づき検証対象の論理回路の論理素子であるファンクシ ョンセルの出力の値であるネット値を観測することによ り、動作状態をシミュレーションして論理検証を行う論 理回路検証方法において、シミュレーション開始後、使 用者が設定した検証時刻に到達した時に入力値検出部を 呼び出す入力値検出部呼出ステップと、前記検証対象回 路で使用されている論理検証用ライブラリのファンクシ ョンセルである検証対象セルのセル名を獲得するセル名 獲得ステップと、前記検証対象セルに入力されるデータ 入力値を獲得する入力値獲得ステップと、前記検証対象 セルの前記セル名から該当するフローティング判定の判 定関数を呼び出す判定関数呼出ステップと、使用者が指 定した指定信号を格納した指定信号リストから前記指定 信号の名称である指定信号名を受け、検出対象セルの入 力信号名が指定信号名と一致しかつ入力信号値がHiZ であるかを判定する指定信号のHiZ判定ステップと、 前記指定信号のHiZ判定ステップで指定信号がHiZ の場合前記入力信号が直接接続されている回路の構成と 無関係に全てエラーと判定するエラー判定ステップと、 前記指定信号のHiZ判定ステップで指定信号がHiZ でない場合前記判定関数での判定条件と一致するかを判 定するフローティング判定ステップと、前記フローティ ング判定ステップで一致する場合エラー又はワーニング と判定するエラー又はワーニング判定ステップと、検証 対象の全てのファンクションセルについて前記入力値検 50

出部呼出ステップから前記エラー又はワーニング判定ス テップまでの処理を反復するファンクションセル終了確 認ステップと、シミュレーション終了時刻まで検証時刻 に到達する毎に前記前記入力値検出部呼出ステップから 前記反復処理ステップまでの処理を繰り返すシミュレー ション終了判定ステップちおを有することを特徴とする ものである。

12

【0029】請求項6記載の発明の論理回路検証方法 は、検証対象回路の論理回路データとテストデータとに 基づき検証対象の論理回路の論理素子であるファンクシ ョンセルの出力の値であるネット値を観測することによ り、動作状態をシミュレーションして論理検証を行う論 理回路検証方法において、シミュレーション開始後、設 定した検証時刻に到達した時に入力値検出部を呼び出す 入力値検出部呼出ステップと、論理検証用ライブラリか ら使用者が指定した指定信号が入力されているファンク ションセルである検証対象セルのセル名を獲得する指定 信号セル名獲得ステップと、前記検証対象セルに入力さ れるデータ入力値を獲得する入力値獲得ステップと、前 記検証対象セルの前記セル名から該当するフローティン グ判定の判定関数を呼び出す判定関数呼出ステップと、 前記使用者が作成した指定信号リストの指定信号名と検 出した信号名とが一致する場合に前記判定関数での判定 条件と一致するかの判定を行うフローティング判定ステ ップと、前記フローティング判定ステップで一致する場 合エラー又はワーニングと判定するエラー又はワーニン グ判定ステップと、検証対象の全ての指定信号について 前記入力値検出部呼出ステップから前記エラー又はワー ニング判定ステップまでの処理を反復するファンクショ ンセル終了確認ステップと、シミュレーション終了時刻 まで検証時刻に到達する毎に前記前記入力値検出部呼出 ステップから前記反復処理ステップまでの処理を繰り返 すシミュレーション終了判定ステップとを有することを 特徴とするものである。

【0030】請求項7記載の発明の論理回路検証装置 は、検証対象回路の論理回路データとテストデータとに 基づき検証対象の論理回路の論理素子であるファンクシ ョンセルの出力の値であるネット値を観測することによ り、動作状態をシミュレーションして論理検証を行う論 理回路検証装置において、前記検証対象回路の論理シミ ュレーション用ライブラリの記述に依存しない実際のデ バイスの回路図から作成した判定関数に基づき論理検証 の対象とする前記ファンクションセルである検証対象セ ルの出力が不定値となる高インピーダンス(以下、Hi Z) 値入力に起因するMOSトランジスタのゲートフロ ーティングで起こる貫通電流発生箇所を検出するフロー ティング判定部を備えて構成される。

【0031】請求項8記載の発明の論理回路検証装置 は、検証対象回路の論理回路データとテストデータとに 基づき検証対象の論理回路の論理素子であるファンクシ

30

ョンセルの出力の値であるネット値を観測することによ り、動作状態を論理シミュレーションして論理検証を行 う論理回路検証装置において、前記テストデータと前記 論理回路データとを入力しこの論理回路データが参照す る後述のファンクションセルの集まりである論理検証用 ライブラリを参照して前記論理シミュレーションを行う シミュレータと、前記シミュレータから検証対象の前記 ファンクションセルである検証対象セルのセル名と入力 値を抽出し出力する入力値検出部と、抽出した前記検証 対象セルのセル名と前記入力値と前記検出対象セルの実 際のデバイスの回路図から作成した判定関数とに基づき 前記検出対象回路が高インピーダンス入力によるゲート フローティングで貫通電流が発生するかの判定を行い判 定結果のメッセージを出力するフローティング判定部 と、前記シミュレータのシミュレーション結果と前記フ ローティング判定部の前記メッセージに基づきシミュレ ーション結果と判定結果を出力する出力処理部とを備え て構成される。

【0032】また、請求項9記載の発明は、請求項8記 載の論理回路検証装置において、前記フローティング判 定部が、前記入力値検出部で抽出した前記セル名と前記 判定関数とセル名の対応リストを参照して前記判定関数 を格納した判定関数ファイルから前記検証対象セルの判 定関数を選択する判定関数選択部と、前記判定関数と前 記セル名のセルの前記入力値とからゲートフローティン グによる貫通電流の発生の有無を判定し判定結果をメッ セージとして出力する判定部とを備えて構成される。

【0033】請求項10記載の発明の論理回路検証装置 は、検証対象回路の論理回路データとテストデータとに 基づき検証対象の論理回路の論理素子であるファンクシ 30 ョンセルの出力の値であるネット値を観測することによ り、動作状態を論理シミュレーションして論理検証を行 う論理回路検証装置において、前記テストデータと前記 論理回路データとを入力しこの論理回路データが参照す る後述のファンクションセルの集まりである論理検証用 ライプラリを参照して前記論理シミュレーションを行う シミュレータと、前記シミュレータから検証対象の前記 ファンクションセルである検証対象セルのセル名と入力 値を抽出し出力する入力値検出部と、抽出した前記検証 対象セルのセル名と前記入力値と前記検出対象セルの実 際のデバイスの回路図から作成した判定関数と入力信号 の種類と入力信号が接続されている回路の種類とに基づ き前記検出対象回路が高インピーダンス入力によるゲー トフローティングで貫通電流が発生するかの判定を行い 判定結果のメッセージを出力するフローティング判定部 と、前記フローティング判定部に必要な前記入力信号の 種類と前記入力信号が接続されている回路の種類を論理 検証用ライブラリと同一階層構造を持つSPICEネッ トリストから抽出するための回路構成抽出部と、前記シ ミュレータのシミュレーション結果と前記フローティン 50

グ判定部の前記メッセージに基づきシミュレーション結 果と判定結果を出力する出力処理部とを備えて構成され る。

【0034】請求項11記載の発明の論理回路検証装置 は、検証対象回路の論理回路データとテストデータとに 基づき検証対象の論理回路の論理素子であるファンクシ ョンセルの出力の値であるネット値を観測することによ り、動作状態を論理シミュレーションして論理検証を行 う論理回路検証装置において、前記テストデータと前記 論理回路データとを入力しこの論理回路データが参照す る後述のファンクションセルの集まりである論理検証用 ライブラリを参照して前記論理シミュレーションを行う シミュレータと、前記シミュレータから検証対象の前記 ファンクションセルである検証対象セルのセル名と入力 値を抽出し出力する入力値検出部と、抽出した前記検証 対象セルのセル名と前記入力値と前記検出対象セルの実 際のデバイスの回路図から作成した判定関数とに基づき 前記検出対象回路が髙インピーダンス入力によるゲート フローティングで貫通電流が発生するかの判定を行うと ともに使用者が指定した指定信号については入力信号が 直接接続されている回路の構成と無関係にデータ入力値 が髙インピーダンス値である場合は全てエラーと判定し て判定結果のメッセージを出力するフローティング判定 部と、前記シミュレータのシミュレーション結果と前記 フローティング判定部の前記メッセージに基づきシミュ レーション結果と判定結果を出力する出力処理部とを備 えて構成される。

#### [0035]

【発明の実施の形態】次に、本発明の実施の形態につい て図面を参照して詳細に説明する。

【0036】本発明の実施の形態の論理回路検証方法 は、検証対象回路の論理回路データとテストデータとに 基づき検証対象の論理回路の論理素子であるファンクシ ョンセルの出力の値であるネット値を観測することによ り、動作状態をシミュレーションして論理検証を行う論 理回路検証方法において、上記検証対象回路の論理シミ ュレーション用ライブラリの記述に依存しない実際のデ バイスの回路図から作成した判定関数に基づき論理検証 の対象とする上記ファンクションセルである検証対象セ ルの出力が不定値となる高インピーダンス(以下、Hi Z) 値入力に起因するMOSトランジスタのゲートフロ ーティングで起こる貫通電流発生箇所を的確に検出する ことを特徴とするものである。

【0037】また、本実施の形態の論理回路検証方法を 行う論理回路検証装置は、検証対象回路の論理回路デー タとテストデータとに基づき検証対象の論理回路の論理 素子であるファンクションセルの出力の値であるネット 値を観測することにより、動作状態をシミュレーション して論理検証を行う論理回路検証装置において、上記検 証対象回路の論理シミュレーション用ライブラリの記述

40

に依存しない実際のデバイスの回路図から作成した判定 関数に基づき論理検証の対象とする上記ファンクション セルである検証対象セルの出力が不定値となるHiZ値 入力に起因するMOSトランジスタのゲートフローティ ングで起こる貫通電流発生箇所を検出するフローティン グ判定部を備えることを特徴とするものである。

【0038】次に、本発明の第1の実施の形態をブロッ クで示す図1を参照すると、この図に示す本実施の形態 の論理回路検証方法を実施する論理回路検証装置は、論 理シミュレータに供給するテストデータF1と検証対象 データである論理回路データF2とを入力し論理回路デ ータF2が参照する後述のファンクションセルの集まり である論理検証用ライブラリF3を参照して論理シミュ レーションを行うシミュレータ1と、シミュレータ1か ら検証対象のファンクションセル(以下、検証対象セ ル)FSのセル名F31と入力値F32を抽出し出力す る入力値検出部2と、入力値検出部2で抽出した検証対 象セルのセル名F31と入力値F32と検出対象セルの 実際のデバイスの回路図から作成した後述の判定関数F 34とに基づき検出対象回路がHiZ入力によるゲート フローティングで貫通電流が発生するかの判定を行い判 定結果のメッセージF35を出力するフローティング判 定部3と、シミュレータ1のシミュレーション結果とフ ローティング判定部3のメッセージF35に基づきシミ ュレーション結果 F 4 と判定結果 F 5 を出力する出力処 理部4とを備える。

【0039】フローティング判定部3の詳細な構成をブロックで示す図2を参照すると、この図に示す本実施の形態を特徴付けるフローティング判定部3は、入力値検出部2で抽出したセル名F31と判定関数とセル名の対 30 応リストF33を参照して判定関数ファイルF34から検証対象のファンクションセルの判定関数F34を選択する判定関数選択部31と、判定関数F34とセル名F31のセルの入力値F32とからゲートフローティングによる貫通電流の発生の有無を判定し判定結果をメッセージF35として出力する判定部32とを備える。

【0040】次に、図1を参照して本実施の形態の動作について説明すると、テストデータF1はシミュレータ1に供給するシミュレーションのための入力信号であり、論理回路データF2は検証の対象とする論理回路のデータである。また、論理検証用ライブラリF3は、シミュレーション用に記述した論理回路の最小の論理(論理素子)であるバッファ、インバータ、AND、OR、フリップフロップ等を定義したモジュールであるファンクションセルの集まりであり、シミュレーション時に論理回路データF2が参照する。

【0041】まず、シミュレータ1は、テストデータF1と論理回路データF2とを入力し論理検証用ライブラリF3を参照して論理シミュレーションを行う。入力値検出部2は、使用者が設定した検証時刻に到達すると、

この検証時刻において、論理検証用ライブラリF3から 論理回路データF2が使用している、すなわち、検証中 のファンクションセル(以下、検証対象セル)のセル名 F31を抽出し、この検証対象セルに入力された入力値 F32をシミュレータ1から抽出する。フローティング 判定部3は、入力値検出部2で抽出した検証対象セルの セル名F31と入力値F32とを入力とし、テストデー タF1対応の入力信号が直接接続されている回路(以 下、直接入力回路)にHi2入力によるゲートフロティングで貫通電流が発生するかの判定を行い、判定結果 のメッセージF35を出力する。出力処理部4は、シミュレータ1のシミュレーション結果4を出力すると共 に、フローティング判定部3の判定結果のメッセージF 35を受けて判定結果F5を出力する。

【0042】次に、図2を参照して、フローティング判定部3の動作の詳細について説明すると、このフローティング判定部3は、論理検証用ライブラリF3に格納されているファンクションセルのうちの検証対象セルのセル名と入力信号値と直接入力回路からHiZ入力によるゲートフローティングによる貫通電流発生の有無を判断するものである。

【0043】フローティング判定部3は、まず、入力値検出部2で抽出したセル名F31とセルの入力値F32を受け取り、判定関数選択部31で判定関数とセル名の対応リストF33から判定関数F34を呼び出し、判定部32に入力する。次に、判定部32は、判定関数F34に対し入力値F32がゲートフローティングによる貫通電流を発生させる場合にエラーと判定する。また、入力信号がセット/リセット信号の場合はワーニングと判定する。このようなセット/リセット信号の情報は、予め判定関数内に設定しておく。最後に、判定部32は判定結果を出力用のメッセージF35として出力する。

【0044】判定関数F34は、実際のデバイスの回路 図から人手により作成する。

【0045】フローティング判定部3の判定関数F34の判定方法の一例を示す表1を参照すると、まず、入力信号がデータ信号と制御信号である場合、直接入力回路がバッファ又はインバータであるならば、データ入力値がHiZの場合にエラーと判定し、データ入力値がHiZの場合は正常と判定する。また、直接入力回路がトライステートバッファまたはクロックドインバータであるならば、データ入力値がHiZかつ制御信号がオンの場合にエラーと判定し、上記以外の場合は正常と判定する。さらに、直接入力回路が上記以外の組み合わせ回路であるならば、データ入力値がHiZかつ他の信号がゲートをオフしない組み合わせの場合にエラーと判定し、上記以外の場合は正常と判定する。

【0046】次に、入力信号がセット/リセット信号の場合は、データ入力値がHiZならば全てワーニングと 判定し、上記以外の場合は正常と判定する。

[0047]

【表1】

| 7 + 150 0 -    | 162 - 122 - 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |                                         |       |
|----------------|-------------------------------------------|-----------------------------------------|-------|
| 入力信号の<br>種類    | 入力信号が直接接統<br>されている回路の種類                   | 判定条件                                    | 判定    |
| データ信号制御信号      | バッファ<br>インバータ                             | データ入力値=HiZ                              | エラー   |
|                |                                           | 上記以外                                    | 正常    |
|                | トライステートバッファ<br>クロックドインバータ                 | データ入力値=HiZと<br>制御信号がONの場合               | エラー   |
|                |                                           | 上記以外                                    | 正常    |
|                | 上記以外の<br>組み合わせ回路                          | データ入力値=HiZと他の信号との<br>組み合わせで回路の出力にX発生の場合 | エラー   |
|                | 12-7 H 12-C [[] 31                        | 上記以外                                    | 正常    |
| セット/<br>リセット信号 | 全て                                        | データ入力値=HiZ                              | ワーニング |
|                |                                           | 上記以外                                    | 正常    |

【0048】以上詳細に実施例の構成を述べたが、シミュレータ1は、任意の時刻に検証対象回路の任意のネット値を抽出できる論理シミュレータ(例えばVerilogシミュレータ)であればよく、この種の論理シミュレータは当業者にとって周知であり、また本発明とは直接関係しないので、その詳細な構成は省略する。

【0049】次に、本実施の形態の論理回路検証方法の処理フローをフローチャートで示す図3を参照して本実施の形態の論理回路検証方法について説明すると、シミュレーション開始後、使用者が設定した検証を希望する時刻である検証時刻に到達した時(ステップS1)に入力値検出部2を呼び出す。

【0050】次に、検証対象となっている回路で使用されている論理検証用ライブラリF3のファンクションセル (検証対象セル)のセル名を獲得し(ステップS2)、次に、論理シミュレーションの検証対象セルに入 30力されるデータ入力値を獲得する(ステップS3)。

【0051】次に、検証対象セルのセル名から該当するフローティング判定の判定関数を呼び出す (ステップS4)。この判定関数での判定条件と一致するかのフローティング判定を行い (ステップS5)、一致するならばエラーまたはワーニングと判定する (ステップS6)。

【0052】検証対象の全てのファンクションセルについてステップS2~S6の判定処理を実施し(ステップS7)、シミュレーション終了時刻まで検証時刻に到達する毎にステップS1~S7の処理を繰り返す(ステッ 40プS8)。

【0053】論理検証用ライブラリF3の回路記述の構造(以下、ライブラリ回路記述)の一例を模式的に及び対応する実際のデバイスの回路構造(以下、実回路)の一例をそれぞれ回路図で示す図4(A)及び図4(B)を併せて参照して、本実施の形態の動作を具体的に説明すると、まず、図4(A)に示すライブラリ回路記述は、入力データ信号Dの入力に応じてデータ信号D1を出力するバッファB1と、クロック信号CLKの入力に応じてクロック信号CLK1を出力するバッファB2

と、データ信号D1とクロック信号CLKとリセット信号RESが入力し出力信号Qを出力するセル名FF1\_1のリセット付のフリップフロップFF1とを有する。【0054】対応する図4(B)の実回路はセル名FF1\_1で表されるリセット付のフリップフロップFF1 Aは、クロックCK1、CKBで制御され入力データ信号Dの入力に応じてデータ信号D1を出力するクロックドインバータG1と、クロック信号CLKの入力に応じてクロック信号CKBを出力するインバータG2と、クロック信号CKBの入力に応じてクロック信号CK1を出力するインバータG3と、データ信号D1とクロック信号CKBの入力に応じてクロック信号CK1を出力するインバータG3と、データ信号RESが入力し出力信号Qを出力する論理回路G4とを有する。

【0055】次に、判定関数とセル名の対応リストF3303の一例をテーブル形式で示す図5を参照すると、この図には例としてインバータの判定関数check\_inv、と、NANDゲートの判定関数check\_nandと、フリップフロップの判定関数check\_ffについて示し、例えば、フリップフロップの判定関数check\_ffは、入力信号数3、セル名FF1\_1,FF1\_2,FF1\_3,FF1\_4等の情報を示されている。

【0056】説明の便宜上、リセット付フリップフロップ FF1のセル名が  $FF1_1$ 、入力データ信号 DがHiZ、クロック信号 CLKが"1"、リセット信号 RE Sが"0"であるものとする。

【0057】この場合、上述した従来の第1の論理検証 手法では、ライブラリ回路記述におけるデータ信号Dが 入力されるバッファB1の出力データ信号D1で不定値 Xを検出するため、擬似エラーを報告する。

【0058】本実施の形態では、まず、入力値検出部2は検出したセル名FF1\_1とデータ入力値、すなわち、入力データ信号D=HiZ、クロック信号CLK="1"、リセット信号RES="0"をフローティング50 判定部3に供給する。

【0059】フローティング判定部3は、判定関数選択 部31が対応リストF33から、検証対象セルであるセ ル名FF1\_1と一致するセル名FF1 1が含まれる 判定関数check\_ffを選択する。

【0060】次に、判定部32は、選択した判定関数c heck\_ffを用い、検出対象セルFF1\_1につい て、表1の判定条件に従って判定を行う。

【0061】判定関数による判定ステップS5におい て、リセット付フリップフロップの判定関数check \_\_ffによる判定方法をフローチャートで示す図6を参 照すると、入力信号AがHiZ値であるかの判定を行う ステップS51と、ステップS51でYesの場合エラ 一又はゲートフローティングによる貫通電流発生を出力 するステップS52と、ステップS51でNoの場合と ステップS52の後、入力信号BがHiZ値であるかの 判定を行うステップS53と、ステップS53でYes の場合エラー又はゲートフローティングによる貫通電流 発生を出力するステップS54と、ステップS53でN \_o の場合とステップS54の後、入力信号CがHi2値 \*\_\_ \*であるかの判定を行うステップS55と、ステップS5 5でYesの場合エラー又はゲートフローティングによ る貫通電流発生を出力するステップS56とを有する。 【0062】この図で示す入力信号AはクロックCLK を、入力信号Bはデータ信号Dを、入力信号Cはリセッ ト信号RESをそれぞれ表す。上記想定により、入力信 号Aが"1"、入力信号BがHi2、入力信号Cが "0"であり、従って、入力信号Aの判定ステップS5 1、入力信号Bの判定ステップS53、入力信号Cの判 定ステップS55はいずれも"No"を選択し、判定結 果はエラー及びワーニングのいずれにもならない。

【0063】表2はリセット付きフリップフロップの入 力信号の組み合わせで本実施の形態の検出方法によるフ ローティング判定のエラー及びワーニングを従来の第1 の論理検証手法によるX発生の検出によるエラーと比較 して示したものである。

[0064] 【表 2 】

| D    | CLE | ال  | 従来手法<br>の判定 | 本発明<br>の判定 | エラー/ワーニングの検出内容                                       |
|------|-----|-----|-------------|------------|------------------------------------------------------|
| 0    |     | 0   | 正常          | 正常         |                                                      |
| Q    | 0   |     | 正常          | 正常         |                                                      |
| 0    | 0   | HiZ | エラー         | エラー        | ワーニング・: リセット信号がHiZ                                   |
| 0    |     | 0   | 正常          | 正常         |                                                      |
| 0    |     |     | 正常          | 正常         |                                                      |
| О    | 1   | HiZ | エラー         | エラー        | ワーニング、: リセット信号がHiZ                                   |
| 0    | HiZ | 0   | エラー         | エラー        | エラー:インバータのゲート浮きによる貫通電流発生                             |
| O    | HiZ | ī   | エラー         | エラー        | エラー: インバータのゲート浮きによる貫通電流発生                            |
| 0    | HiZ | HiZ | エラー         | エラー        | エラー: インバーダのゲート浮きによる<br>貫通電流発生ノケーニング・・リセット信号がHiZ      |
| 1    | 0   | 0   | 正常          | 正常         |                                                      |
| 1    | 0   |     | 正常          | 正常         |                                                      |
| 1    | 0   | HiZ | エラー         | エラー        | ワーニング : リセット信号がHi Z                                  |
| 1    | 1   | 0   | 正常          | 正常         |                                                      |
|      | 1   | 1   | 正常          | 正常         |                                                      |
| 1    | 1   | HiZ | エラー         | エラー        | ワーニング・リセット信号がHiZ                                     |
| 1    | HiZ |     | エラー         | エラー        | エラー:インバータのケート浮きによる貫通電流発生                             |
| li T | HiZ | ī   | エラー         | エラー        | エラー: インハータのケート浮きによる貫通電流発生                            |
| 1    | HiZ | HiZ |             | エラー        | ェテー: インバーダのゲート浮きによる<br>貫通電流発生/ワーニング: リセット信号がHiZ      |
| HiZ  | 0   | 0   | エラー         | エラー        | エラー: クロックドインバーサのゲート浮きによる<br>貫通電流発生                   |
| HiZ  | 0   | 1   | エラー         | エラー        | エラー: クロックドインバーサのゲート浮きによる<br>貫通電流発生                   |
| HiZ  | 0   | HiZ | エラー         | エラー        | エラー: クロックドインバータのゲート浮きによる<br>貫通電流発生/ワーニング: リセット信号がHiZ |
| HiZ  | 1   | 0   | エラー         | 正常         |                                                      |
| HiZ  |     | 1   | エラー         | 正常         |                                                      |
| HiZ  |     | HiZ | エラー         | エラー        | ワーニング : リセット信号がHi Z                                  |
| HIZ  | HiZ | 0   | エラー         | エラー        | エラー:インバータのゲート浮きによる貫通電振発生                             |
| HiZ  | HiZ |     | エラー         |            | エラー: インバータのゲート浮きによる貫通電流発生                            |
| HiZ  | HiZ | HiZ | エラー         | エラー        | エラー:インバータのゲート浮きによる<br>貫通電流発生/ワーニング:リセット信号がHiZ        |
|      |     |     |             |            |                                                      |

【0065】表2において、検出内容は本実施の形態の フローティング判定部3の検出方法で出力されるエラー メッセージF35の種類を示す。入力データ信号DがH i Z、クロック信号CLKが"1"、リセット信号RE

回路検証方法では、この例のライブラリ回路記述におい てデータ信号Dが入力されるバッファB1の出力データ 信号D1で不定値Xを検出するが、本実施の形態のフロ ーティング判定部3の検出方法における判定結果では検 Sが"O"又は"1"である場合に、従来の第2の論理 50 出されない。実回路では、貫通電流を発生しないので従

来の第2の論理回路検証方法の判定は擬似エラーであ る。

21

【0066】このように、本実施の形態は、擬似エラー を排除し、HiZ入力によるゲートフローティングでゲ ート電位が不安定となり中間電位のときにPチャネルト ランジスタ及びNチャネルトランジスタが同時にオンす ることにより生じる貫通電流の発生個所を正確に検出可 能となる。

【0067】次に、本発明の第2の実施の形態を特徴付 けるフローティング判定部 3 Aの判定方法を示す表 3 を 10 参照すると、第1の実施の形態では、判定関数 F34に \*

\*より入力信号がセット/リセット信号の場合は、データ 入力値がHiZならば全てワーニングと判定していたの に対し、本実施の形態ではデータ信号及び制御信号と同 様に、直接入力回路の種類と判定条件とからエラーと正 常とに分類することである。

22

【0068】これにより、本実施の形態では、全信号に 対して実回路と同一の検出結果を得ることが可能とな

[0069] 【表3】

| 入力信号の<br>種類 | 入力信号が直接接続<br>されている回路の <del>種類</del> | 判定条件                                          | 判定  |
|-------------|-------------------------------------|-----------------------------------------------|-----|
| 全ての信号       | バッファ<br>インバータ                       | データ入力値=HiZ                                    | エラー |
|             | 1 2 1 - 9                           | 上記以外                                          | 正常  |
|             | トライステートバッファ<br>クロックドインバータ           | データ入力値=HiZと<br>制御信号がONの場合                     | エラー |
|             | 7 5 9 7 1 7 7 1 - 9                 | 上記以外                                          | 正常  |
|             | 上記以外の組み合わせ回路                        | データ入力値=HiZと他の信号との組み合わせで<br>プリミティブセルの出力にX発生の場合 | エラー |
|             | 成のアロインと日田                           | 上記以外                                          | 正常  |

【0070】次に、本発明の第3の実施の形態を図1と 共通の構成要素には共通の参照文字/数字を付して同様 にブロックで示す図7を参照すると、この図に示す本実 施の形態の前述の第1の実施の形態との相違点は、フロ ーティング判定部3の代わりに第1の実施の形態の判定 条件に加えて入力信号の種類と入力信号が接続されてい る回路の種類を用いてフローテング検出を行うフローテ ング判定部3Bと、このフローティング判定部3Bに必 要な入力信号の種類と入力信号が接続されている回路の 種類を論理検証用ライブラリF3と同一階層構造を持つ SPICEネットリストF6から抽出するための回路構 成抽出部5を備えていることである。

【0071】次に、図7を参照して本実施の形態の動作 について第1の実施の形態との相違点を重点的に説明す ると、回路構成抽出部5は論理検証用ライブラリF3と 同一階層構造を持つSPICEネットリストF6からフ アンクションセルのセル名、入力信号名、入力信号が直 接接続されている素子との接続関係からフローティング 40 判定部3Bの判定関数F34に必要な回路の種類と判定 条件を作成する。

【0072】回路構成抽出部5の処理をフローチャート で示す図8を参照してこの回路構成抽出部5の動作につ いて説明すると、まず、SPICEネットリストF6か らセルの入力端子がゲートに接続された論理素子である 場合 (ステップS61)、この論理素子の子の種類、ゲ ート名、ソース名、ドレイン名の情報を素子リストF5 1として作成する(ステップS62)。素子リストF5

子の情報を格納した素子リストへのポインタを格納する (ステップS63)。接続されている素子のソース又は ドレインが電源VDD又は接地GNDになるまで素子リ ストF51を追加していく(ステップS64)。ファイ ルの最後まで調べたら (ステップS65)、素子リスト F51からPチャネル素子、Nチャネル素子の接続関係 を抽出する(ステップS66)。接続関係から回路構造 に一致する判定式を論理構成の定義をした回路構成リス トF51の中から選択し(ステップS67)、選択した 回路構成の判定式にゲートの信号名を設定する (ステッ プS68)。回路構成抽出部5で信号名を設定した回路 構成の判定式をフローティング判定部3Bの判定関数で 使用する。素子リストF51の最後までステップS66 ~ S 6 9 を反復する。

【0073】素子リストF51の構成の一例をテーブル 形式で示す図9を参照すると、この素子リストF51 は、モデル名、ゲート節点名、ソース節点名、ソース節 点数、ソースに節点に接続された素子リストへのポイン タ、ドレイン節点名、ドレイン節点数、ドレイン節点に 接続された素子リストへのポインタから構成されてい る。

【0074】本実施の形態の素子リストF51の作成方 法を説明図で示す図10を参照すると、SPICEネッ トリストF6から入力端子として定義されているIN1 がゲート入力されている素子を抽出し最初の素子リスト F511を作成する。上記素子のソース節点に接続され ている素子の情報を素子リストF512に作成しこの素 1にはソース又はドレインを共有する素子数及びその素 50 子リストF512のポインタを素子リストF512へ格

納する。

【0075】IN1がゲート接続されている素子のドレイン節点はVDDに接続されているため次の素子リストの数に"0"、次の素子リストへのポインタに"null"を格納する。ソース節点及びドレイン節点がVDD又はGNDに接続されている場合は同様に、次の素子リストの数に"0"、次の素子リストへのポインタに"null"を格納する。VDD、GNDへの節点の接続以外は、接続先の素子リストを作成しそのポインタを接続元の素子リストへ格納する。接続先の素子リストへのポインタは節点数に応じて動的に生成する。以下、上記手順で素子リストF51を構成する残りの素子リストF513~F518を作成する。

【0076】生成した素子リストから素子の接続関係を抽出し、回路構成リストF52で定義した回路構成に一致する判定式を選択する。選択した判定式にゲート信号名を与えて判定式を作成する。このように、本実施の形態では、SPICEネットリストから回路構成を抽出するため、ライブラリの変更にも早期に対応でき、適用対象が広がり早期に品質を保証できるという効果が得られ 20る。

【0077】回路構成リストF52の一例を示す図11を参照すると、接続関係のPはPチャネルトランジスタ、NはNチャネルトランジスタ、"\*"は並列接続、"丨"は直列接続を表す。

【0078】図10の実施の形態の素子リストは、"P-P-N-N"に一致するので、判定式は"IN1=HiZ&P1=0&P2=1"となる。

【0079】次に、本発明の第4の実施の形態を図3と 共通の構成要素には共通の参照文字/数字を付して同様 にフローチャートで示す図12を参照すると、この図に 示す本実施の形態の前述の第1の実施の形態との相違点 は、フローティング判定の判定関数呼出ステップS4と フローティング判定ステップS5の間に該当する判定関 数の有無を判定する判定関数有無判定ステップS9と、 判定関数がない場合に検証対象外であることを警告する 検証対象外警告ステップS11とを有し、フローティン グ判定部の判定関数とセル名の対応リストに合致しない セルが使用されている場合にそのセル名を告知すること である。

【0080】次に、図12を参照して本実施の形態の動作について第1の実施の形態との相違点を重点的に説明すると、シミュレーション開始後、第1の実施の形態と同様のステップS1~S4の処理を行う。すなわち、検証時刻に到達した時(ステップS1)に入力値検出部2を呼び出し、検証対象セルのゼル名を獲得し(ステップS2)、次に、検証対象セルのデータ入力値を獲得する(ステップS3)。セル名から該当するフローティング判定の判定関数を呼び出す(ステップS4)。

【0081】次に、ステップS9で、判定関数呼出ステ 50

ップS4で呼び出すべき判定関数の有無を判定し、該当する判定関数がない場合には、検証対象セルが判定対象外である旨の告知対象とする(ステップS10)。

【0082】次に、ステップS9で、判定関数呼出ステップS4で呼び出すべき判定関数が有る場合は、ステップS5に進み、以下第1の実施の形態と同一のステップS5〜S8の処理を行う。すなわち、この判定関数での判定条件と一致するならば(ステップS5)、エラー又はワーニングと判定する(ステップS6)。検証対象の全てのファンクションセルについてステップS2〜S6の判定処理を実施し(ステップS7)、シミュレーション終了時刻まで検証時刻に到達する毎にステップS1〜S7の処理を繰り返す(ステップS8)。

【0083】このように、検証対象外となるファンクションセルを検出することにより検証もれを防止すること が可能となる。

【0084】次に、本発明の第5の実施の形態を特徴付けるフローティング判定部3Cの判定方法を示し第2の実施の形態で用いた表3を参照して説明すると、この第5の実施の形態は、第2の実施の形態と同様に、入力信号がセット/リセット信号の場合でも、データ信号及び制御信号と同様に直接入力回路の種類と判定条件からエラーと正常とに分類する。さらに第4の実施の形態と同様に検証対象外となったファンクションセルの告知を行う。

【0085】次に、本発明の第6の実施の形態を図1と 共通の構成要素には共通の参照文字/数字を付して同様 にブロックで示す図13を参照すると、この図に示す本 実施の形態の前述の第1の実施の形態との相違点は、フローティング判定部3の代わりに使用者が指定した指定 信号について直接入力回路の構成と無関係にデータ入力 値がHiZである場合は全てエラーと判定するフローティング判定部3Dと、上記指定信号のリストである指定 信号リストF7とを備えることである。

【0086】また、本実施の形態の処理を図3と共通の構成要素には共通の参照文字/数字を付して同様にフローチャートで示す図14を参照すると、この図に示す本実施の形態の前述の第1の実施の形態との相違点は、フローティング判定の判定関数呼出ステップS4の後に指定信号リストの信号名との一致と入力信号のHi2の条件を判定するステップS11と、ステップS11の判定結果Yesの場合エラーを出力するステップS12と、ステップS11の判定結果Noの場合判定条件との一致を判定するステップS13と、ステップS13の判定結果Yesの場合エラー又はワーニングを出力するステップS14とを有することである。

【0087】次に、図13及び図14を参照して本実施の形態の動作について第1の実施の形態との相違点を重点的に説明すると、フローティング判定部3Dは、入力値検出部から出力される検証対象セルのセル名F31と

30

10

20

その入力値F32の供給を受け(ステップS1~S 3)、セル名から該当するフローティング判定の判定関 数を呼び出す(ステップS4)。また指定信号リストF 7から使用者が指定した指定信号の名称である指定信号 名を受け、検出対象セルの入力信号名F31が指定信号 名と一致しかつ入力信号値がHiZであるかを判定する (ステップS11)。ステップS11でYesの場合、 直接入力回路の回路構成とは無関係に全てエラーと判定 し(ステップS12)、Noの場合判定関数での判定条 件と一致するかを判定する(ステップS13)。ステッ プS13での判定結果、Yesの場合、エラー又はワー ニングと判定する。

【0088】次に、検証対象の全てのファンクションセ ルについてステップS2~S4, S11~S14の判定 処理を実施し(ステップS7)、シミュレーション終了 時刻まで検証時刻に到達する毎にステップS2~S4, S11~S14, S7の処理を繰り返す (ステップS 8) .

【0089】なお、エラーの判定(ステップS12)を ワーニングの判定に換えてもよい。

【0090】次に、本発明の第7の実施の形態を図3と 共通の構成要素には共通の参照文字/数字を付して同様 にフローチャートで示す図15を参照すると、この図に 示す本実施の形態の前述の第1の実施の形態との相違点 は、ステップS2の代わりに検証対象セル名として指定 信号が入力されているファンクションセルのセル名を獲 得するステップS15と、ステップS5の代わりに指定 信号名と検出した信号名が一致する場合に判定関数での 判定条件との一致判定ステップS16と、ステップS7 の代わりに全ての指定信号について検証したかの確認ス テップS17とを有し、使用者が指定した指定信号に対 してのみ、第1の実施の形態と同様に検出を行うことで ある。

【0091】次に、図15を参照して本実施の形態の動 作について第1の実施の形態との相違点を重点的に説明 すると、まず、検証時刻に到達した時 (ステップS1) に入力値検出部2を呼び出し、論理検証用ライブラリか ら指定信号が入力されているファンクションセルである 検証対象セルのセル名を獲得し(ステップS15)、次 に、検証対象セルのデータ入力値を獲得する (ステップ S3)。セル名から該当するフローティング判定の判定 関数を呼び出す(ステップS4)。

【0092】次に、使用者が作成した指定信号リストの 指定信号名と検出した信号名が一致する場合に上記判定 関数での判定条件と一致するならば(ステップS1 6)、エラー又はワーニングと判定する(ステップS 6)。

【0093】検証対象の全ての指定信号についてステッ プS15, S3, S4, S16, S6、S17の判定処

時刻まで検証時刻に到達する毎にステップS1S15, S3, S4, S16, S6、S17, S8の処理を繰り 返す (ステップS8)。

【0094】これにより、検証対象を絞り込むことが可 能となり検証時間を短縮できる。

【0095】次に、本発明の第8の実施の形態を図7と 共通の構成要素には共通の参照文字/数字を付して同様 にブロックで示す図16を参照すると、この図に示す本 実施の形態の前述の第3の実施の形態との相違点は、、フ ローティング判定部3Bの代わりに入力信号の種類と入 力信号が接続されている回路の種類と使用者が指定した 指定信号のみに基づき検出対象回路がHiZ入力による ゲートフローティングで貫通電流が発生するかの判定を 行い判定結果のメッセージF35を出力するフローティ ング判定部3Eと、指定信号リストF7とを備えること である。

【0096】次に、図16を参照して本実施の形態の動 作について説明すると、指定信号のみを入力信号とし、 この入力信号がセット/リセット信号でありデータ入力。 値がHi Zである場合に、全て「ワーニング」と判定 し、データ信号及び制御信号は直接入力回路の種類と判 定条件から表1のようにエラーと正常とに分類する。

【0097】以上説明したように、本発明の論理回路検 証方法とその装置は、次のような効果を奏する。

【0098】第1の効果は、HiZ入力でのゲートフロ ーティングによる貫通電流発生個所を実際のデバイスと 同一の個所で検出でき、擬似エラーも発生しないことか ら貫通電流発生個所の特定も容易にであり、解析時間を 短縮できることである。さらに擬似エラーが検出されな いため真のエラーを見落とすことがない。その理由は、 論理シミュレーション用ライブラリの記述に依存しない 実際のデバイスに基づいたフローティング判定部を備え るためである。

【0099】第2の効果は、設計段階で貫通電流の発生 個所を発見できるため、設計工程の後戻りが少なく開発 製品を早期に市場へ投入できることである。その理由 は、従来実際のデバイス評価で発見していた個所を論理 シミュレーションで検出できるためである。

【0100】第3の効果は、レジスタトランスファレベ ルでの構文チェッカを使用してHiZ入力でゲートフロ 40 ーティングにより貫通電流の発生可能性のある個所を検 出し修正する場合、ゲートレベルで手修正した場合には 不具合が発生する可能性がある。手修正後に本発明の検 証方法を実施することにより不具合の作り込みを防止し 設計品質が保たれる。

#### [0101]

【発明の効果】以上説明したように、本発明の論理回路 検証方法とその装置は、検証対象回路の論理シミュレー ション用ライブラリの記述に依存しない実際のデバイス 理を実施し(ステップS17)、シミュレーション終了 50 の回路図から作成した判定関数に基づきHiZ値入力に

28

起因するMOSトランジスタのゲートフローティングで起こる貫通電流発生箇所を的確に検出するフローティング判定部を備えることにより、HiZ入力でゲートフローティングによる貫通電流の発生個所を実際のデバイスと同一の個所で検出でき、擬似エラーも発生しないことから貫通電流発生個所の特定も容易であり、解析時間を短縮できるという効果がある。

【0102】また、擬似エラーが検出されないため真のエラーを見落とすことがないという効果がある。従来、実際のデバイス評価で発見していた貫通電流の発生個所 10を設計段階の論理シミュレーションで発見できるため、設計工程の後戻りが少なく開発製品を早期に市場へ投入できるという効果がある。

【0103】さらに、レジスタトランスファレベルでの 構文チェッカを使用してHiZ入力でゲートフローティ ングにより貫通電流の発生可能性のある個所を検出し修 正する場合、ゲートレベルで手修正した場合には不具合 が発生する可能性があるが、手修正後に本発明の検証を 実施することにより不具合の作り込みを防止し設計品質 を保持できるという効果がある。

# 【図面の簡単な説明】

【図1】本発明の第1の実施の形態の論理回路検証方法 を実施する論理回路検証装置を示すブロック図である。

【図2】図1のフローティング判定部の詳細な構成を示すブロック図である。

【図3】本実施の形態の論理回路検証方法の一例を示す フローチャートである。

【図4】 論理検証用ライブラリの回路記述の構造の一例 及び対応する実際のデバイスの回路構造の一例をそれぞ れ示す回路図である。

【図5】判定関数とセル名の対応リストの一例をテーブル形式で示す説明図である。

【図6】リセット付フリップフロップの判定関数による 判定方法を示すフローチャートである。

【図7】本発明の第3の実施の形態の論理回路検証方法 を実施する論理回路検証装置を示すブロック図である。

【図8】図7の回路構成抽出部の処理を示すフローチャートである。

【図9】素子リストの構成の一例をテーブル形式で示す 図である。

【図10】本実施の形態の素子リストの作成方法を示す 説明図である。

【図11】回路構成リストの一例を示す説明図である。

【図12】本発明の第4の実施の形態の論理回路検証方法を示すフローチャートである。

【図13】本発明の第6の実施の形態の論理回路検証方法を実施する論理回路検証装置を示すブロック図である。

【図14】本実施の形態の論理回路検証方法を示すフローチャートである。

【図15】本発明の第7の実施の形態の論理回路検証方法を示すフローチャートである。

【図16】本発明の第8の実施の形態の論理回路検証方法を実施する論理回路検証装置を示すブロック図である。

【図17】従来の第1の論理回路検証装置の一例を示す ブロック図である。

10 【図18】従来の第2の論理回路検証装置の一例を示す ブロック図である。

【図19】論理シミュレーション用ライブラリの第1及 び第2の例としてそれぞれトライステートバッファの論 理記述を模式的に示した回路図である。

#### 【符号の説明】

1,101 シミュレータ

2 入力値検出部

3,3A,3B,3C,3D,3E フローティング --判定部

20 4 出力処理部

5 回路構成抽出部

31 判定関数選択部

32 判定部

102 出力検出部

103 出力処理部

201 論理回路図作成装置

202 ネットリスト入力部

203 ライブラリ入力部

204 検証部

30 205 エラー/ワーニング出力部

206 検証ルール記憶領域

B1, B2 バッファ

F1, F101 テストデータ

F2, F102 論理回路データ

F 5 判定結果

F6 SPICEネットリスト

F7 指定信号リスト

F51 素子リスト

F4, F103 シミュレーション結果

40 F31 セル名

F32 入力値

F33 対応リスト

F34 判定関数

F35 メッセージ

FF1 フリップフロップ

G1~G3 インバータ

G 4 論理回路





【図12】



【図14】



【図16】



【図17】



【図15】



【図19】





【図18】

